<template>
  <el-cascader
    :value="value"
    size="mini"
    :options="treeData"
    :props="props"
    separator="-"
    @change="changeValue"
  />
</template>
<script>
import { getDepartment } from '@/api/department'
import { transListToTreeData } from '@/utils/index'
export default {
  props: {
    value: {
      type: Number, // 存储的是部门id
      default: null
    }
  },
  data() {
    return {
      treeData: [], // 赋值给 联级组件的option
      props: {
        value: 'id', // 要存储的字段
        label: 'name' // 要展示的字段
      }
    }
  },
  created() {
    this.getDepartment()
  },
  methods: {
    async getDepartment() {
      this.treeData = transListToTreeData(await getDepartment(), 0)// 将组织架构的数据 转化树形赋值给treeData
    },
    changeValue(list) {
      // 取到数组的最后一次
      if (list.length > 0) {
        this.$emit('input', list[list.length - 1]) // 将最后一位的id取出来 传出去
      } else {
        this.$emit('input', null)// 如果长度为0说明值为空
      }
    }
  }
}
</script>
